(function() {
    tinymce.create('tinymce.plugins.SpCommGmap', {
        /**
         * Initializes the plugin, this will be executed after the plugin has been created.
         * This call is done before the editor instance has finished it's initialization so use the onInit event
         * of the editor instance to intercept that event.
         *
         * @param {tinymce.Editor} ed Editor instance that the plugin is initialized in.
         * @param {string} url Absolute URL to where the plugin is located.
         */
        init : function(ed, url) {
 			ed.addButton('addmap', {
                title : 'Google Map',
                cmd : 'addmap',
                image : url + '/../images/tinymce-bt-map.png',
            });
			ed.addCommand('addmap', function() {
				ed.insertContent('[map address="'+spcGmapVars.address+'" width="'+spcGmapVars.width+'" height="'+spcGmapVars.height+'" zoom="'+spcGmapVars.zoom+'" image="'+spcGmapVars.image+'" link="'+spcGmapVars.link+'" lat="'+spcGmapVars.lat+'" lng ="'+spcGmapVars.lng+'" ]');
			});
        },
 
        /**
         * Creates control instances based in the incomming name. This method is normally not
         * needed since the addButton method of the tinymce.Editor class is a more easy way of adding buttons
         * but you sometimes need to create more complex controls like listboxes, split buttons etc then this
         * method can be used to create those.
         *
         * @param {String} n Name of the control to create.
         * @param {tinymce.ControlManager} cm Control manager to use inorder to create new control.
         * @return {tinymce.ui.Control} New control instance or null if no control was created.
         */
        createControl : function(n, cm) {
            return null;
        },
 
        /**
         * Returns information about the plugin as a name/value array.
         * The current keys are longname, author, authorurl, infourl and version.
         *
         * @return {Object} Name/value array containing information about the plugin.
         */
        getInfo : function() {
            return {
                longname : 'SpCommGmap Buttons',
                author : 'SAMsan',
                authorurl : 'https://github.com/5AMsan',
                infourl : 'https://github.com/5AMsan/WP_Plugin-spcommGmap',
                version : "0.1"
            };
        }
    });
 
    // Register plugin
    tinymce.PluginManager.add( 'SpCommGmap', tinymce.plugins.SpCommGmap );
})();